<script>
export default {
  name: "XSteps",
  props: {
    active: {
      type: Number,
      default: 1,
    },
  },
  setup() {},
  render() {
    //获取插槽
    const items = this.$slots.default();
    // console.log(items);
    //动态节点，有可能用这个组件的时候使用的是v-for生成的节点，这样需要转换
    const dynamicItems = [];
    items.forEach((item) => {
      if (item.type.name) {
        dynamicItems.push(item);
      } else {
        item.children.forEach((item) => {
          dynamicItems.push(item);
        });
      }
    });

    const itemJSX = dynamicItems.map((item, i) => {
      return (
        <div class="xtx-steps-item" class={{ active: i < this.active }}>
          <div class="step">
            <span>{i + 1}</span>
          </div>
          <div class="title">{item.props.title}</div>
          <div class="desc">{item.props.desc}</div>
        </div>
      );
    });

    return <div class="xtx-steps">{itemJSX}</div>;
  },
};
</script>
<style lang="less">
.xtx-steps {
  display: flex;
  text-align: center;
  &-item {
    flex: 1;
    &:first-child {
      .step {
        &::before {
          display: none;
        }
      }
    }
    &:last-child {
      .step {
        &::after {
          display: none;
        }
      }
    }
    &.active {
      .step {
        > span {
          border-color: @xtxColor;
          background: @xtxColor;
          color: #fff;
        }
        &::before,
        &::after {
          background: @xtxColor;
        }
      }
      .title {
        color: @xtxColor;
      }
    }
    .step {
      position: relative;
      > span {
        width: 48px;
        height: 48px;
        font-size: 28px;
        border: 2px solid #e4e4e4;
        background: #fff;
        border-radius: 50%;
        line-height: 44px;
        color: #ccc;
        display: inline-block;
        position: relative;
        z-index: 1;
      }
      &::after,
      &::before {
        content: "";
        position: absolute;
        top: 23px;
        width: 50%;
        height: 2px;
        background: #e4e4e4;
      }
      &::before {
        left: 0;
      }
      &::after {
        right: 0;
      }
    }
    .title {
      color: #999;
      padding-top: 12px;
    }
    .desc {
      font-size: 12px;
      color: #999;
      padding-top: 6px;
    }
  }
}
</style>